IN THE CLAIMS 



Please cancel claims 1-4, 9-13, 16-21, 23-24 and 27-28. 
Please amend the claims as follows. 

1 1-4 (Cancelled) 

1 5. (Currently Amended) An apparatus comprising: 



2 at least one processor; 

3 a memory coupled to the at least one processor; 

4 a database table residing in the memory; 

5 a query residing in the memory that accesses the database table; and 

6 a query optimizer residing in the memory and executed by the at least one 



7 processor, wherein the query optimizer analyzes the query, and if no optimal index for the 

8 query exists, the query optimizer determines if a sub-optimal index exists, a sub-optimal 

9 index including at least one key referenced in the query and additionally including at least 

10 one additional key that prevents traversal of the sub-optimal index to determine the 

1 1 number of rows that the query will return, wherein if a sub-optimal index exists, the query 

12 optimizer, for each additional key in the sub-optimal index, reads statistical information 

13 regarding the additional key, the query optimizer rewriting the query using the statistical 

14 information in a manner that allows probing the sub-optimal index according to the 

15 rewritten query, the query optimizer thereby determining from the sub-optimal index an 

16 estimated number of rows in the database table that satisfy the quer y, the query optimizer 

17 optimizing the query based on the estimated number of rows in the database table that 

18 satisfy the query . 

1 6. (Original) The apparatus of claim 5 wherein the statistical information comprises a 

2 frequent values list that corresponds to an additional key. 



2 



1 7. (Currently Amended) An apparatus comprising: 

2 at least one processor; 

3 a memory coupled to the at least one processor; 

4 a database table residing in the memory; 

5 a query residing in the memory that accesses the database table; 

6 an index residing in the memory that includes at least one key referenced in the 

7 query and additionally includes at least one additional key that prevents traversal of the 

8 index to determine the number of rows that the query will return; and 

9 a query optimizer residing in the memory and executed by the at least one 



10 processor, wherein the query optimizer, for each additional key in the index, reads 

1 1 statistical information regarding the additional key, the query optimizer rewriting the 

12 query using the statistical information in a manner that allows probing the index 

1 3 according to the rewritten query, the query optimizer thereby determining from the index 

14 an estimated number of rows in the database table that satisfy the quer y, the query 

15 optimizer optimizing the query based on the estimated number of rows in the database 

16 table that satisfy the query . 

1 8. (Original) The apparatus of claim 7 wherein the statistical information comprises a 

2 frequent values list that corresponds to an additional key. 

1 9-13 (Cancelled) 



3 



1 14. (Currently Amended) A method for optimizing a database query for a database table, 

2 the method comprising the steps of: 

3 (1) analyzing the query; 

4 (2) if no optimal index for the query exists, determining if a sub-optimal index 

5 exists, a sub-optimal index including at least one key referenced in the query and 

6 additionally including at least one additional key that prevents traversal of the sub- 

7 optimal index to determine the number of rows that the query will return; 

8 (3) if a sub-optimal index exists, performing the following steps for each 

9 additional key in the sub-optimal index that prevents traversal of the sub-optimal index to 

10 determine the number of rows that the query will return: 

1 1 (A) reading statistical information regarding the additional key; and 

12 (B) rewriting the query using the statistical information in a manner that 

13 allows probing the sub-optimal index according to the rewritten query; 

14 (4) probing the sub-optimal index using the rewritten query; [[and]] 

15 (5) determining from the probe of the sub-optimal index an estimated number of 

1 6 rows in the database table that satisfy the quer y; and 

17 (6) optimizing the query based on the estimated number of rows in the database 

18 table that satisfy the query . 

1 15. (Currently Amended) The method of claim [[9]] 14 wherein the statistical 

2 information comprises a frequent values list that corresponds to an additional key. 

1 16-21 (Cancelled) 
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1 22. (Currently Amended) A computer-readable program product comprising: 

2 (A) a query optimizer that analyzes a query for a database table, and if no optimal 

3 index for the query exists, the query optimizer determines if a sub-optimal index exists, a 

4 sub-optimal index including at least one key referenced in the query and additionally 

5 including at least one additional key that prevents traversal of the sub-optimal index to 

6 determine the number of rows that the query will return, wherein if a sub-optimal index 

7 exists, the query optimizer, for each additional key in the sub-optimal index, reads 

8 statistical information regarding the additional key, the query optimizer rewriting the 

9 query using the statistical information in a manner that allows probing the sub-optimal 

10 index according to the rewritten query, the query optimizer thereby determining from the 

1 1 sub-optimal index an estimated number of rows in the database table that satisfy the 

12 quer y, the query optimizer optimizing the query based on the estimated number of rows 

13 in the database table that satisfy the query : and 

1 4 (B) computer readable signal bearing recordable media bearing the query 

15 optimizer. 

1 23-24 (Cancelled) 

1 25. (Original) The program product of claim 22 wherein the statistical information 

2 comprises a frequent values list that corresponds to an additional key. 
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1 26. (Currently Amended) A computer-readable program product comprising: 

2 (A) a query optimizer that processes a query for a database table using a sub- 

3 optimal index that includes at least one key referenced in the query and additionally 

4 includes at least one additional key that prevents traversal of the sub-optimal index to 

5 determine the number of rows that the query will return, wherein the query optimizer, for 

6 each additional key in the index, reads statistical information regarding the additional key, 

7 the query optimizer rewriting the query using the statistical information in a manner that 

8 allows probing the index according to the rewritten query, the query optimizer thereby 

9 determining from the index an estimated number of rows in the database table that satisfy 

10 the quer y, the query optimizer optimizing the query based on the estimated number of 

1 1 rows in the database table that satisfy the query ; and 

1 2 (B) computer readable signal bearing recordable media bearing the query 

13 optimizer. 

1 27-28 (Cancelled) 

1 29. (Original) The program product of claim 26 wherein the statistical information 

2 comprises a frequent values list that corresponds to an additional key. 
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